草庐IT

database - 用户表 - redis 或 postgres

全部标签

ruby-on-rails - 如何通过 session ID 找到设计用户?

给定session["session_id"]是否可以找到该session所属的已登录User? 最佳答案 至少在我的系统上(rails3.2,devise2.0.4),你可以这样做:session是:{"session_id"=>"be02f27d504672bab3408a0ccf5c1db5","_csrf_token"=>"DKaCNX3/DMloaCHbVSNq33NJjYIg51X0z/p2T1VRzfY=","warden.user.user.key"=>["User",[3],"$2a$10$5HFWNuz5p6fT

ruby-on-rails - Rails 3.2 Postgres 保存错误 "ActiveRecord::StatementInvalid: PG::Error: ERROR: Syntax error near ' T' 在位置 5"

当我尝试将特定类保存到数据库时,我的应用开始抛出错误。我不确定到底是什么原因导致这种情况开始发生-过去几天我一直遇到各种数据库问题....无论如何,我的模型似乎工作正常(它正在正确计算所有before_save值),但随后它尝试保存到数据库并爆炸。SQL(0.8ms)INSERTINTO"portfolios"("correlation_matrix","created_at","data","mean_return","std_dev","updated_at","weights")VALUES($1,$2,$3,$4,$5,$6,$7)RETURNING"id"[["correla

ruby-on-rails - Rails Migration 更改列以使用 Postgres 数组

我正在尝试更改数据库中的列,以便它可以使用Postgres数组数据类型。目前表列是字符串类型。我正在使用以下迁移来转换它:defchangechange_column:table,:dummy_column,:text,array:true,default:[]end但是我得到以下错误:bundleexecrakedb:migraterakeaborted!Anerrorhasoccurred,thisandalllatermigrationscanceled:PG::Error:ERROR:column"dummy_column"cannotbecastautomaticallyto

ruby - 如何在使用门卫的 oauth 提供商上为我的用户预授权客户端应用程序?

我编写了一个oauth提供程序,旨在与我公司的几个Web应用程序一起使用。我正在使用doorkeepergem,到目前为止效果很好。典型的行为是用户转到客户端应用程序,被重定向到提供商以登录,确认客户端应用程序有权访问该用户的信息,然后被重定向回客户端应用程序。但是,我想跳过用户确认客户端应用程序的步骤。我想为他们做,所以没有提示。我试图模仿代码Ifoundhere像这样:Doorkeeper::Application.all.eachdo|application|auth_params={response_type:'code',client_id:application.uid,r

ruby-on-rails - 在 Web 服务器上执行用户提供的 ruby​​ 代码

我想让我的用户创建Ruby脚本,对驻留在Web服务器上的某些数据进行计算,然后输出结果。脚本在服务器上执行。有什么方法可以安全地做到这一点?更具体地说,我想:限制脚本可以使用的资源(内存和cpu),并限制其运行时间限制脚本可以使用哪些核心类(例如String、Fixnum、Float、Math等)让脚本访问和返回数据向用户输出任何错误是否有任何库或项目可以满足我的要求?如果不是Ruby,也许是其他语言? 最佳答案 您可以使用“空白板”作为干净的房间,并使用沙箱来设置safelevel到4。一张白纸,一个你已经从中剥离了所有方法的对象

ruby-on-rails - 使用 Authlogic 和 Authlogic OAuth 插件隐式创建用户

我正在尝试在Rails中编写一个简单的OAuth消费者应用程序。我正在使用Authlogic处理身份验证,并使用AuthlogicOAuth插件来执行oauth。oauth插件提供了几个助手来呈现登录按钮:oauth_login_button和oauth_register_button。与Authlogic逻辑和插件的请求过滤器一起,这两个按钮以某种方式创建了session/用户。接下来发生的事情如下:-如果我使用oauth_login_button助手,则session对象无法保存,因为本地没有这样的用户。-如果我使用oauth_register_button助手,那么,在第一次登录

ruby - 轨道 3 :how to generate models for existing database tables

我已经将我的database.yml配置为指向我现有的mysql数据库我如何从中生成模型?railsgeneratemodelexisting_table_name只给出一个空模型.. 最佳答案 你可以试试Rmre.它可以为现有模式创建模型,并尝试根据外键信息创建所有关系。 关于ruby-轨道3:howtogeneratemodelsforexistingdatabasetables,我们在StackOverflow上找到一个类似的问题: https://st

ruby-on-rails - 设计可确认 - 当用户尝试使用未经确认的电子邮件登录时,将用户重定向到自定义页面

启用Confirmable模块后,Devise将不允许未经确认的用户在预定义的时间段过去后登录。相反,用户会被重定向回登录页面,并显示一条闪现消息“您必须先确认您的帐户才能继续”。这是一种不受欢迎的交互模式,因为快速通知没有提供足够的空间来向用户正确解释访问被拒绝的原因、“确认您的帐户”的含义、提供重新发送确认的链接以及关于如何检查您的垃圾邮件文件夹等。有没有办法改变这种行为,改为重定向到特定的URL? 最佳答案 抱歉,一开始我以为您指的是“注册”之后,而不是“登录”。因此,下面的内容适用于如何在注册后指导用户以及您需要为登录做的是

ruby-on-rails - Rails 5 如何清除或删除生产 postgres 数据库

我正在尝试删除生产数据库,以便重新开始。当我从rails4升级到rails5时,它现在正在保护生产数据库不被意外删除。它在我运行rakedb:reset时显示以下错误消息。/app#rakedb:resetActiveRecord::SchemaMigrationLoad(1.8ms)SELECT"schema_migrations".*FROM"schema_migrations"(1.6ms)SELECT"ar_internal_metadata"."value"FROM"ar_internal_metadata"WHERE"ar_internal_metadata"."key"=

ruby-on-rails - 处理用户发送的 "string contains null byte"

我有一个APIController,它使用PostgreSQL/Rails接收有关媒体文件路径和id3标签的信息,并将它们保存到ActiveRecord实例。有时用户会发送如下字符串:"genre"=>"Hip-Hop\u0000Hip-Hop/Rap"当试图坚持save时,Rails/Postgres对此并不十分满意:AnArgumentErroroccurredininternals#receive:stringcontainsnullbyteactiverecord(3.2.21)lib/active_record/connection_adapters/postgresql_a